草庐IT

Java TLS-PSK 套接字

全部标签

node.js - UDP 和网络套接字的数据丢失

我有以下场景:本地PC通过蓝牙以50.000位/秒的速度接收数据样本。数据通过UDP发送到某个服务器。服务器依次通过网页/JavaScript和网络套接字将数据分发到处理数据的已连接浏览器。最终,来自浏览器的结果通过UDP传回本地PC。到目前为止,我正在试验严格的本地设置,即一切都在一台拥有四核CPU的机器上运行。我已经用node.js和golang编写了服务器代码。在这两种情况下,都存在严重的数据丢失,即即使只有一个Web套接字客户端连接,也并非服务器成功接收到通过UDP发送的每个样本。造成损失的瓶颈在哪里?一切都在本地机器上运行是事实吗?会不会是websocket带宽太小了?使用W

go - 由于 CLOSE_WAIT 和 TIME_WAIT 套接字上升导致代理服务器不稳定

我有一个用golang编写的socks5代理服务器。守护进程正在监听从15000到25000的10000个端口,所以这是一个代理列表。最近我们开始对一些客户进行测试,最终我们在其中5000个端口上获得了大约500rps。这不是我想的那么多,但我立即指出了一堆问题。服务器是Ubuntu18,8核,32G内存,1Gb网络。我一直观察到几乎800%的CPU,并且CLOSE_WAIT和TIME_WAIT套接字状态的数量不断增加。我仔细调查了大约一个星期的代码,但没有指出任何问题,所有连接都在关闭。pprof说这都是关于系统调用的,更准确地说是套接字读取。这里的ReadAtLeast是读取soc

sockets - 去写套接字 - 无效参数

我试图在Go中写入一个TCP套接字,但只收到带有此代码的“无效参数”:_,err:=conn.Write([]byte("test"))iferr!=nil{fmt.Println(err.Error())} 最佳答案 这是一个简单的例子,说明你想做什么(也许?),请注意你应该让tcp服务器在运行之前先监听端口8999nc-l8999#ormaybenc-l-p8999代码:packagemainimport("net")funcmain(){conn,_:=net.Dial("tcp","localhost:8999")conn.

google-app-engine - 如何使用 Go 运行时在 App Engine 上的实例之间传递套接字?

Python运行时通过picklingtheconnection允许它.是否有类似的方式在经典AppEngine上使用Go运行时与google.golang.org/appengine/socket共享套接字? 最佳答案 描述符未在GoAPI中公开:https://github.com/golang/appengine/blob/master/socket/socket_classic.go#L152typeConnstruct{ctxcontext.Contextdescstringoffsetint64protpb.Create

ruby - 这个示例 tcp 套接字编程事件顺序安全吗?

我计划提供两项服务。用Ruby编写的HTTPREST服务用Go编写的JSONRPC服务Ruby服务将打开一个到GoJSONRPC服务的TCP套接字连接。它将为收到的每个传入HTTP请求执行此操作。它会通过套接字向Go服务发送一些数据,然后该服务会通过套接字发回相应的数据。Go代码Go服务go看起来像这样(简化):srv:=new(service.App)//thiswouldexposeaProcessmethodrpc.Register(srv)listener,err:=net.Listen("tcp",":8080")iferr!=nil{//handleerror}for{co

sockets - 检索确切的连接 - tcp 套接字 - channel - goroutine

我正在学习Golang几天,所以我不清楚如何在函数内检索正确的连接“conn”函数处理消息对于相关消息“msg”谢谢!packagemainimport("fmt""log""net""os""encoding/json""time""bufio")typePacketstruct{PayloadPayload`json:"payload"`}typePayloadstruct{Datastring`json:"data"`}funcmain(){iflen(os.Args)!=2{fmt.Fprintf(os.Stderr,"Usage:%shostname\n",os.Args[0

json - go 中的 ZeroMQ 不会打印我从 PULL 套接字接收到的 json 消息字节

我正在尝试一个简单的代码:packagemainimport("fmt"zmq"github.com/alecthomas/gozmq")funcmain(){context,_:=zmq.NewContext()defercontext.Close()//Sockettoreceivemessagesonreceiver,_:=context.NewSocket(zmq.PULL)deferreceiver.Close()receiver.Connect("tcp://localhost:5557")//Processtasksforeverfor{msgbytes,_:=recei

Golang unix 套接字 : registering same type for RPC on different sockets?

我在Go中工作,对使用unix套接字有点陌生。尝试搜索类似的问题,但找不到任何内容,如果之前已经回答过,我们深表歉意。我想用unixsockets模拟一个机器集群进行测试。我正在测试我的Raft实现,所以我想在不同的unix套接字上注册相同类型的多个对象(一个庞大的结构)。但是看我写的一个简单的例子,效果似乎不是我想要的:为同一个导出方法拨不同的套接字似乎在单个端口上崩溃:packagemainimport("net""fmt""net/rpc""log""sync")typeServerstruct{namestring}typeSpeakArgsstruct{}typeSpeakR

mysql - Golang Mysql connectex 套接字 block

我使用“go-sql-driver/mysql”驱动程序。我有一个具有一些依赖项的产品表。所以我选择产品并获取将在子查询中创建笛卡尔产品的依赖项。通常有200个产品限制以获得更好的性能,但在极少数情况下,该限制将被删除或提高到比方说3000-5000然后我会收到以下错误:dialtcp127.0.0.1:3306:connectex:NormalerweisedarfjedeSocketadresse(Protokoll,NetzwerkadresseoderAnschluss)nurjeweilseinmalverwendetwerden.这基本上意味着:connectex:Usee

sockets - golang grpc 套接字调整

我有一个golang客户端应用程序通过GRPC与服务器通信。我注意到,在应用程序运行时,客户端应用程序上累积的套接字数量一直在攀升,直到9000左右。此时我暂停了客户端。然而,在客户端和服务器之间不再有流量之后,即使在8小时后,套接字数量仍保持在该水平。我们是否可以针对套接字使用调整GRPC?比如超时后关闭套接字?使用流式传输是否是另一种限制打开的套接字数量的方法?感谢您的帮助。 最佳答案 我首先要确保您的客户端应用程序通过调用Close()方法清除未使用的连接(grpc.ClientConn)。此外,由于我不知道您的应用程序究竟做